测试程序

    其中项目中的 pom.xml 是配置了 9999 端口。你也可以通过下面的方法修改属性

    下面是控制台的主要输出(删除了部分行)

    Listing 11.5 Compile and start the ChatServer

    可以在浏览器中通过 http://localhost:9999 地址访问程序。图11.5展示了此程序在Chrome浏览器下的用户界面。

    Figure 11.5 WebSockets ChatServer demonstration

    图中显示了两个已经连接了的客户端。第一个客户端是通过上面的图形界面连接的,第二个是通过Chrome浏览器底部的命令行连接的。
    你可以注意到,这两个客户端都在发送消息,每条消息都会显示在两个客户端上。

    在实际场景中,加密是必不可少的。在Netty中实现加密并不麻烦,你只需要向 ChannelPipeline 中添加 SslHandler ,然后配置一下即可。如下:

    Listing 11.6 Add encryption to the ChannelPipeline

    1. public class SecureChatServerIntializer extends ChatServerInitializer { //1
    2. private final SslContext context;
    3. public SecureChatServerIntializer(ChannelGroup group, SslContext context) {
    4. super(group);
    5. this.context = context;
    6. }
    7. @Override
    8. super.initChannel(ch);
    9. SSLEngine engine = context.newEngine(ch.alloc());
    10. engine.setUseClientMode(false);
    11. ch.pipeline().addFirst(new SslHandler(engine)); //2
    12. }
    13. }

    1.扩展 ChatServerInitializer 来实现加密

    2.向 ChannelPipeline 中添加SslHandler

    Listing 11.7 Add encryption to the ChatServer

    1.扩展 ChatServer

    2.返回先前创建的 SecureChatServerInitializer 来启用加密

    这样,就在所有的通信中使用了 加密。和前面一样,你可以使用Maven拉取应用需要的所有依赖,并启动它,如下所示。

    Listing 11.8 Start the SecureChatServer

    1. $ mvn -PSecureChatServer clean package exec:exec
    2. [INFO]
    3. [INFO] Building ChatServer 1.0-SNAPSHOT
    4. [INFO] ------------------------------------------------------------------------
    5. ...
    6. [INFO]
    7. [INFO] --- maven-jar-plugin:2.4:jar (default-jar) @ netty-in-action ---
    8. [INFO] Building jar: D:/netty-in-action/chapter11/target/chat-server-1.0-SNAPSHOT.jar
    9. [INFO]
    10. Starting SecureChatServer on port 9999